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DETAILED ACTION 



1. 



Claims 1-20 pending. 



Response to Amendment 



2. The 1.131 Affidavit filed on 12/1 1/2006 is accepted and will be entered into the 
record. As such the Kamentz reference and all rejections associated with it are 
withdrawn. However, a new rejection in view of Gong shall replace the previous 
rejection. 



3. The following is a quotation of the appropriate paragraphs of 35 U.S.C. 1 02 that 
form the basis for the rejections under this section made in this Office action: 
A person shall be entitled to a patent unless - 

(e) the invention was described in (1) an application for patent, published under section 122(b), by 
another filed in the United States before the invention by the applicant for patent or (2) a patent 
granted on an application for patent by another filed in the United States before the invention by the 
applicant for patent, except that an international application filed under the treaty defined in section 
351(a) shall have the effects for purposes of this subsection of an application filed in the United States 
only if the international application designated the United States and was published under Article 21(2) 
. of such treaty in the English language. 



4. Claims 1-2, 4-9, 11-16, and 18-20 rejected under 35 U.S.C. 102(e) as being 
anticipated by Gong ("Secure Java Class Loading", IEEE Internet Computing, Novermber/December 



Claim Rejections - 35 USC § 102 



1998, Pgs. 56-61). 
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As per Claims 1 , 8, and 15, Gong discloses a method, system and computer 
program product for compiling source code using a compiler having a classpath (i.e. 
"Second, compilers and a bytecode verifier ensure that the Java virtual machine executes only legitimate 
Java code. The bytecode verifier, together with the Java virtual machine, guarantees language type 
safety at runtime. Moreover, a class loader defines a local name space, which helps to ensure that an 
untrusted applet cannot interfere with the running of other Java programs." The preceding text excerpt 
clearly indicates compilers compile source code (e.g. byte code) which has class loaders (e.g. a class 
path).) (Page 57, Insert), comprising the steps of: 1) determining if a referenced class file is 
located in a workspace (i.e. "Class loading has several unique characteristics. First, lazy loading 
means that classes are loaded on demand, on a just-in-time basis. Second, dynamic class loading 
maintains the type safety of the Java virtual machine by adding link-time checks, which replace certain 
runtime checks and are performed only once. Moreover, programmers can define their own class loaders 
that, for example, specify the remote location from which certain classes are loaded, or assign 
appropriate security attributes to them. Finally, programmers can use class loaders to provide separate 
name spaces for various software components. For example, a browser can load applets from different 
Web pages using separate class loaders, thus maintaining a degree of isolation between those applet 
classes. In fact, these applets can contain classes of the same name— the Java virtual machine treats 
these classes as distinct types." The preceding text excerpt clearly indicates that to load a class, the 
classpath specified in the class loader is checked, and then the workspace indicated in the classpath is 
check to determine if the referenced class file is located there.) (Page 58, Column 2, Paragraph 3); 2) 
locating said class file in said workspace (i.e. "Class loading has several unique characteristics. 
First, lazy loading means that classes are loaded on demand, on a just-in-time basis. Second, dynamic 
class loading maintains the type safety of the Java virtual machine by adding link-time checks, which 
replace certain runtime checks and are performed only once. Moreover, programmers can define their 
own class loaders that, for example, specify the remote location from which certain classes are loaded, or 
assign appropriate security attributes to them. Finally, programmers can use class loaders to provide 
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separate name spaces for various software components. For example, a browser can load applets from 
different Web pages using separate class loaders, thus maintaining a degree of isolation between those 
applet classes. In fact, these applets can contain classes of the same name — the Java virtual machine 
treats these classes as distinct types." The preceding text excerpt clearly indicates that after it has been 
determined that the class file is present, it is located in the workspace.) (Page 58, Column 2, Paragraph 
3); 3) accessing said class file (i.e. ""The preceding text excerpt clearly indicates that the class file 
is eventually loaded, which indicates that it is accessed and then returned to the compiler.) (Page 58, 
Column 2, Paragraph 3); and 4) returning said class file data to said compiler (i.e. "Class 
loading has several unique characteristics. First, lazy loading means that classes are loaded on demand, 
on a just-in-time basis. Second, dynamic class loading maintains the type safety of the Java virtual 
machine by adding link-time checks, which replace certain runtime checks and are performed only once. 
Moreover, programmers can define their own class loaders that, for example, specify the remote location 
from which certain classes are loaded, or assign appropriate security attributes to them. Finally, 
programmers can use class loaders to provide separate name spaces for various software components. 
For example, a browser can load applets from different Web pages using separate class loaders, thus 
maintaining a degree of isolation between those applet classes. In fact, these applets can contain classes 
of the same name— the Java virtual machine treats these classes as distinct types." The preceding text 
excerpt clearly indicates that after it has been determined that the class file is present, it is located in the 
workspace.) (Page 58, Column 2, Paragraph 3); 3) accessing said class file (i.e. ""The preceding 
text excerpt clearly indicates that the class file is eventually loaded, which indicates that it is accessed 
and then returned to the compiler.) (Page 58, Column 2, Paragraph 3). 

As per Claims 2, 9, and 16, Gong discloses the step of locating said class file 
further comprises the steps of: identifying a location of a class using a workspace 
indicator in said classpath (i.e. "Class loading has several unique characteristics. First, lazy loading 
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means that classes are loaded on demand, on a just-in-time basis. Second, dynamic class loading 
maintains the type safety of the Java virtual machine by adding link-time checks, which replace certain 
runtime checks and are performed only once. Moreover, programmers can define their own class loaders 
that, for example, specify the remote location from which certain classes are loaded, or assign 
appropriate security attributes to them. Finally, programmers can use class loaders to provide separate 
name spaces for various software components. For example, a browser can load applets from different 
Web pages using separate class loaders, thus maintaining a degree of isolation between those applet 
classes. In fact, these applets can contain classes of the same name— the Java virtual machine treats 
these classes as distinct types." The preceding text excerpt clearly indicates that a workspace indicator is 
located in the class loader (e.g. the programmer specified location for the workspace).) (Page 58, Column 
2, Paragraph 3); and reading said class from saidjocation (i.e. "Class loading has several unique 
characteristics. First, lazy loading means that classes are loaded on demand, on a just-in-time basis. 
Second, dynamic class loading maintains the type safety of the Java virtual machine by adding link-time 
checks, which replace certain runtime checks and are performed only once. Moreover, programmers can- 
define their own class loaders that, for example, specify the remote location from which certain classes 
are loaded, or assign appropriate security attributes to them. Finally, programmers can use class loaders 
to provide separate name spaces for various software components. For example, a browser can load 
applets from different Web pages using separate class loaders, thus maintaining a degree of isolation 
between those applet classes. In fact, these applets can contain classes of the same name— the Java 
virtual machine treats these classes as distinct types." The preceding text excerpt clearly indicates that 
the class is loaded from the given location.) (Page 58, Column 2, Paragraph 3). 

As per Claims 4 and 1 1 , Gong discloses the step of determining if a referenced 
class file is located in a workspace further comprises the steps of: reading an item from 
said classpath (i.e. To achieve this goal, JDK 1.2 distinguishes genuine system classes from all other 
classes by means of separate class paths. One is the system class path, for storing system classes. The 
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other is the application class path, for storing all other classes. The Java virtual machine still loads 
classes on the system class path with the primordial class loader or a URLCIassLoader and trusts them 
by default. A URLCIassLoader usually loads classes on the application class path, and the Java virtual 
machine grants such classes the appropriate permissions according to the security policy." The preceding 
text excerpt clearly indicates an item is read from the classpath to determine the location of the class.) 
(Page 61, Column 1, Paragraph 5); determining if said item references said file system or said 

workspace (i.e. To achieve this goal, JDK 1.2 distinguishes genuine system classes from all other 
classes by means of separate class paths. One is the system class path, for storing system classes. The 
other is the application class path, for storing all other classes. The Java virtual machine still loads 
classes on the system class path with the primordial class loader or a URLCIassLoader and trusts them 
by default. A URLCIassLoader usually loads classes on the application class path, and the Java virtual 
machine grants such classes the appropriate permissions according to the security policy." The preceding 
text excerpt clearly indicates that the class loader determines whether the item is referencing a system, or 
workspace class by determining which classpath it was read from.) (Page 61, Column 1, Paragraph 5); 
searching a file system directory specified by said item if said item references said file 
system (i.e. 'To achieve this goal, JDK 1.2 distinguishes genuine system classes from all other classes 
by means of separate class paths. One is the system class path, for storing system classes. The other is 
the application class path, for storing all other classes. The Java virtual machine still loads classes on the 
system class path with the primordial class loader or a URLCIassLoader and trusts them by default. A 
URLCIassLoader usually loads classes on the application class path, and the Java virtual machine grants 
such classes the appropriate permissions according to the security policy." The preceding text excerpt 
clearly indicates that the item is located and loaded from either the system or the workspace as per the 
determination of where it is loacated.) (Page 61, Column 1, Paragraph 5); and searching said 
workspace if said item references said workspace (i.e. "To achieve this goal, jdk 1.2 
distinguishes genuine system classes from all other classes by means of separate class paths. One is the 
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system class path, for storing system classes. The other is the application class path, for storing all other 
classes. The Java virtual machine still loads classes on the system class path with the primordial class 
loader or a URLCIassLoader and trusts them by default. A URLCIassLoader usually loads classes on the 
application class path, and the Java virtual machine grants such classes the appropriate permissions 
according to the security policy." The preceding text excerpt clearly indicates that the item is located and 
loaded from either the system or the workspace as per the determination of where it is loacated.) (Page 
61, Column 1, Paragraph 5). 

As per Claims 5, 12, and 18, Gong discloses said class file data is contained in a 
database (i.e. "An individual class representation is called a class file, even though it need not be stored 
in an actual file. For example, class files can be stored as records or commands in a database. " The 
preceding text excerpt clearly indicates that the class file may be contained in a database.) (Page 58, 
Column 2, Paragraph 4). 

As per Claims 6, 13, and 19, Gong discloses said class file is contained within a 
JAR file in said workspace (i.e. "For example, on Unix systems, the class path can be set via the 
Shell environment variable CLASSPATH. Essentially, all classes or Java Archive files containing classes 
on the local file system must reside on this path to be discovered. " The preceding text excerpt clearly 
indicates that the class file may be contained in a Java Archive (e.g. Jar) file.) (Page 61, Column 1, 
Paragraph 3). 

As per Claims 7, 14, and 20, Gong discloses said source code is Java (Note that 
the paper discusses Java classes and JDK, which indicates that the source code would be in Java.). 
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Claim Rejections - 35 USC § 103 

5. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 

obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set 
forth in section 102 of this title, if the differences between the subject matter sought to be patented and 
the prior art are such that the subject matter as a whole would have been obvious at the time the 
invention was made to a person having ordinary skill in the art to which said subject matter pertains. 
Patentability shall not be negatived by the manner in which the invention was made. 

6. Claims 3, 10, and 17 rejected under 35 U.S.C. 103(a) as being unpatentable over 
Gong in view of Bobbitt et al (U.S Pre Grant Publication Number 2003/0115218 and referred to 
hereinafter as Bobbitt). 

As per Claims 3, 10, and 17, Gong fails to disclose said indicator comprises a 
signature string, a user ID, a project ID, and a workspace name. 

Bobbitt discloses said indicator comprises a signature string, a user ID, a project 
ID, and a workspace name (i.e. "The directory structure stored in Gossamer namespace parallels 
the virtual directory hierarchy , wherein the files contained (logically) in the virtual directories are replaced 
by file pointers having the same names as the original files.. Accordingly, the respective file pointers to 
these files having the same namespace and located in the same subdirectory path ("/user/joe") relative to 
the /Namespace directory are stored in Gossamer namespace. " The preceding text excerpt clearly 
indicates that the classpath indicator, as disclosed above, may consist of a signature string (e.g. a pointer 
which identifies the file/class file in its virtual file system/workspace location) which consist of a user ID 
(e.g. joe in user/joe), a project ID (e.g. represented by user in /user) and a workspace name (e.g. 
represented by /Namespace).) (Page 5, Paragraph 0053). 

. It would have been obvious to one skilled in the art at the time of Applicants 
invention to modify the teachings of Gong with the teachings of Bobbitt to include said 
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indicator comprises a signature string, a user ID, a project ID, and a workspace name 
with the motivation of allowing access to files in a virtual file system (e.g. a workspace) 
by using a file pathname to identify the file and map it to a location which is accessible 
from outside the virtual file system (e.g. workspace) (Bobbin, Page 1, Paragraph 8). 
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